## **LAB 6**

## OBJECTIVE: To design and simulate a **Full** **Adder Circuit** using VHDL, and verify its functionality using a testbench.

## TOOLS USED:

* VHDL (VHSIC Hardware Description Language)
* <https://www.edaplayground.com/> (for simulation)

**THEORY:**

A Full Adder adds three one-bit binary numbers (A, B, and Carry-in) and outputs a Sum and a Carry-out. It performs the function:

* Sum (S) = A XOR B XOR Cin
* Carry-out (Cout) = (A XOR B) AND Cin OR (A AND B)

## VHDL CODE

**DESIGN**

library ieee;

use ieee.std\_logic\_1164.all;

entity fa is

port(

a: in std\_ulogic;

b: in std\_ulogic;

cin: in std\_ulogic;

cout: out std\_ulogic;

s: out std\_ulogic

);

end fa;

architecture behave of fa is

begin

s <= (a xor b) xor cin;

cout <= ((a xor b) and cin) or (a and b);

end behave;

**TESTBENCH**

library ieee;

use ieee.std\_logic\_1164.all;

entity fa\_testbench is

end fa\_testbench;

architecture test of fa\_testbench is

component fa

port(

a: in std\_ulogic;

b: in std\_ulogic;

cin: in std\_ulogic;

cout: out std\_ulogic;

s: out std\_ulogic

);

end component;

signal ain, bin, cin, cout, sum : std\_logic;

begin

full\_adder: fa port map (a => ain, b => bin, cin => cin, cout => cout, s => sum);

process begin

ain <= '0';bin <= '0';cin <= '0';wait for 1 ns;

ain <= '0';bin <= '0';cin <= '1';wait for 1 ns;

ain <= '0';bin <= '1';cin <= '0';wait for 1 ns;

ain <= '0';bin <= '1';cin <= '1';wait for 1 ns;

ain <= '1';bin <= '0';cin <= '0';wait for 1 ns;

ain <= '1';bin <= '0';cin <= '1';wait for 1 ns;

ain <= '1';bin <= '1';cin <= '0';wait for 1 ns;

ain <= '1';bin <= '1';cin <= '1';wait for 1 ns;

assert false report "Reached end of test";

wait;

end process;

end test;

Output:

![](data:image/png;base64,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)

CONCLUSION:

The Full Adder was successfully implemented and simulated in VHDL. All possible input combinations were tested, and the output matched the expected values as per the truth table. This confirms the correct functionality of the Full Adder logic.